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REVERSIBLE DOT FOR LOSSLESS -LOSSY COMPRESSION 



The present invention relates to the field of the 
compression and decompression systems; more particularly, the 
present invention relates to lossless discrete cosine 
transform (DCT) -based compression which is reversible. 



The Discrete Cosine Transform (DCT) is an irrational transform 
commonly used in lossy image compression. The DCT is commonly 
used in lossy image compression. It is used in many modes of the JPEG 
standard and the MPEG standards and future HDTV in the United States. 
For a discussion on the various standards, see ISO Standard documents 
ISO/EEC 10918 (JPEG), 11172 (MPEG 1), 13818 (MPEG 2) and William B. 
Pennebaker and Joan L. Mitchell, 7PEG Still Image Data Compression 
Standard/ 1993. The basis vectors of DCT have irrational values. 
Theoretically, integer inputs result in irrational transform coefficients. 
Therefore, infinite precision is required to perform those transforms 
exactly. For use in compression, transform coefficients must be rounded 
to a finite representation. 

With most transform implementations, the rounding coefficients 
to integers does not guarantee that every unique integer input results in a 
different output. Therefore, the inverse DCT cannot reconstruct the 



input exactly. The error due to forward and inverse DCT transforms 
without quantization is referred to as systemic error. This systemic error 
prevents DCT implementations from being used in lossless compression 
without retaining a difference or error image. 
5 In practical DCT implementations, the transform basis vectors are 

also rounded. The difference between a given implementation and the 
ideal transform (or a high accuracy floating point implementation) is 
referred to as mismatch. Low mismatch is required for data interchange. 
There can be a tradeoff between the amount of mismatch and speed, cost 

1 0 and other desirable features. 

A parameterized transform referred to herein as the Allen 
Parameterized Transform (APT) is a family of fast transforms which can 
implement the DCT or rational transforms that are arbitrarily close to the 
DCT. The APT is also referred to as a generalized Chen transform (GCT) 

1 5 For more information on the APT, see J. Allen, "Generalized Chen 
Transform: A Fast Transform for Image Compression," Journal of 
Electronic Imag in g . Vol. 3(4), October 1994, pgs. 341-347; J. Allen, "An 
Approach to Fast Transform Coding in Software," Si gnal Processing : 
Image Communication, Vol. 8, pp. 3-11, 1996; and U.S. Patent No. 

20 5,129,015. 

The present invention provides a reversible block based transform, 
such as, for example, a reversible DCT. The DCT of the present invention 
may be included in a DCT-based compressor/decompressor that may be 



r 



4 

used in a lossless compression /decompression system. The present 
invention also provides DCT transforms with no systemic error and no 
(or low) mismatch. 
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A reversible Discrete Cosine Transform (DCT) is described. The 
reversible DCT may be part of a compressor in a system. The system may 
include a decompressor with a reversible inverse DCT for lossless 
5 decompression or a legacy decompressor with an inverse DCT for lossy 
decompression. 

In one embodiment, the compressor comprises a DCT compressor 
having a multiple rotations (e.g., 2 point (2x2) integer rotations), a 4 point 
parametrized transform, and a subsidiary matrix. The 4 point transform 
1 0 comprises a rotation by B, while the subsidiary matrix comprises a 
rotation by A and a rotation by C 

The present invention also provides a method for creating a look 
up table for rounding offsets for use in a reversible DCT. 



6 

The present invention will be understood more fully from the 
detailed description given below and from the accompanying drawings of 
various embodiments of the invention, which, however, should not be 
5 taken to limit the invention to the specific embodiments, but are for 
explanation and understanding only. 

Figure 1A is a block diagram of one embodiment of a lossless and 
lossy DCT based compression system. 

10 

Figure IB is a block diagram of one embodiment of the compressor 
of the present invention. 

Figure 1C is a block diagram of an alternate embodiment of the 
1 5 compressor of the present invention. 

Figure 2 is a block diagram of one embodiment of a video 
authoring system. 

20 Figure 3 A illustrates a block diagram of one embodiment of a one 

dimensional (ID), 8-point forward parameterized transform. 

Figure 3B illustrates intermediate values in a parameterized 
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transform which have the same scale factor. 

Figure 4 illustrates the Hein form of the subsidiary matrix of 
Figure 3A. 

5 

Figure 5A is a block diagram of one embodiment of an 8-point 
Hadamard transform according to the present invention. 

Figure 5B is a block diagram of one embodiment of an 8-point Haar 
10 transform according to the present invention. 

Figure 5C is a block diagram of one embodiment of a 4-point Sine 
transform according to the present invention. 

1 5 Figure 5D is a block diagram of one embodiment of a 4-point Slant 

transform according to the present invention. 

Figure 6 illustrates one embodiment of a forward ladder filter of a 
2-point rotation. 

20 

Figure 7 illustrates one embodiment of an inverse ladder filter of a 
2-point rotation. 
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Figure 8 illustrates a portion of the mapping for a 45° rotation. 

Figure 9 illustrates extras ("+") and collisions ("o") for 45° rotation. 

5 Figure 10 is a plot of collisions and extras in a 2,1 almost balanced 

transform. 

Figure 11 illustrates one embodiment of a look up table of part of a 
"B" 2-point rotation. 

10 

Figure 12 is a block diagram of one embodiment of a rotation 
according to the present invention. 



A reversible DCT-based compression/ decompression apparatus 
and method are described. In the following detailed description of the 
present invention numerous specific details are set forth, such as types of 
transforms, coefficient sizes, etc., in order to provide a thorough 
understanding of the present invention. However, it will be apparent to 
one skilled in the art that the present invention may be practiced without 
these specific details. In other instances, well-known structures and 
devices are shown in block diagram form, rather than in detail, in order 
to avoid obscuring the present invention. 

Some portions of the detailed descriptions which follow are 
presented in terms of algorithms and symbolic representations of 
operations on data bits within a computer memory. These algorithmic 
descriptions and representations are the means used by those skilled in 
the data processing arts to most effectively convey the substance of their 
work to others skilled in the art. An algorithm is here, and generally, 
conceived to be a self-consistent sequence of steps leading to a desired 
result. The steps are those requiring physical manipulations of physical 
quantities. Usually, though not necessarily, these quantities take the 
form of electrical or magnetic signals capable of being stored, transferred, 
combined, compared, and otherwise manipulated. It has proven 
convenient at times, principally for reasons of common usage, to refer to 
these signals as bits, values, elements, symbols, characters, terms, 



numbers, or the like. 

Some portions of the detailed descriptions which follow are 
presented in terms of algorithms and symbolic representations of 
operations on data bits within a computer memory. These algorithmic 
5 descriptions and representations are the means used by those skilled in 
the data processing arts to most effectively convey the substance of their 
work to others skilled in the art. An algorithm is here, and generally, 
conceived to be a self-consistent sequence of steps leading to a desired 
result. The steps are those requiring physical manipulations of physical 

1 0 quantities. Usually, though not necessarily, these quantities take the 

form of electrical or magnetic signals capable of being stored, transferred, 
combined, compared, and otherwise manipulated. It has proven 
convenient at times, principally for reasons of common usage, to refer to 
these signals as bits, values, elements, symbols, characters, terms, 

1 5 numbers, or the like. 

It should be borne in mind, however, that all of these and similar 
terms are to be associated with the appropriate physical quantities and are 
merely convenient labels applied to these quantities. Unless specifically 
stated otherwise as apparent from the following discussions, it is 

20 appreciated that throughout the present invention, discussions u tilizin g 
terms such as "processing" or "computing* or "calculating" or 
"determining" or "displaying" or the like, refer to the action and 
processes of a computer system, or similar electronic computing device, 



that manipulates and transforms data represented as physical (electronic) 
quantities within the computer system's registers and memories into 
other data similarly represented as physical quantities within the 
computer system memories or registers or other such information 
5 storage, transmission or display devices. Such computer systems typically 
employ one or more processors to process data, which are coupled to one 
or more memories via one or more buses. 

The present invention also relates to apparatus for performing the 
operations herein. This apparatus may be specially constructed for the 

1 0 required purposes, or it may comprise a general purpose computer 

selectively activated or reconfigured by a computer program stored in the 
computer. Such a computer program may be stored in a computer 
readable storage medium, such as, but is not limited to, any type of disk 
including floppy disks, optical disks, CD-ROMs, and magneto-optical 

1 5 disks, read-only memories (ROMs), random access memories (RAMs), 
EPROMs, EEPROMs, magnet or optical cards, or any type of media 
suitable for storing electronic instructions, and each coupled to a 
computer system bus. The algorithms and displays presented herein are 
not inherently related to any particular computer or other apparatus. 

20 Various general purpose machines may be used with programs in 
accordance with the teachings herein, or it may prove convenient to 
construct more specialized apparatus to perform the required method 
steps. The required structure for a variety of these machines will appear 
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from the description below. In addition, the present invention is not 
described with reference to any particular programming language. It will 
be appreciated that a variety of programming languages may be used to 
implement the teachings of the invention as described herein. 

5 

Overview of the Present Invention 

The present invention provides a reversible transform that allows 
DCT-based compression to be lossy and lossless. Reversible Transforms 
are efficient transforms implemented with integer arithmetic whose 

1 0 compressed results can be reconstructed into the original. One 

embodiment of the reversible transform is an extension of the APT. 

The reversible transforms of the present invention are efficient (or 
almost efficient), in that there is no redundancy in the least significant 
bits of the coefficients. That is, the transforms of the present invention 

1 5 are efficient in that they do not require a large number of bits of precision 
(which would otherwise be used in an attempt to eliminate the systemic 
error. Efficiency leads to better lossless compression than using a non- 
reversible transform with a difference image. Several methods of 
constructing reversible APT implementations are described below. The 

20 reversible APT has many applications, such as in video authoring 
systems. 

While transform coefficients may be rounded to any degree of 
precision, the present invention rounds transform coefficients to 



integers. Rounding more coarsely than to integers eliminates 
information and is a type of quantization. Rounding more finely than to 
integers introduces redundancy in the least significant bits of the 
transform coefficients, hindering compression. 
5 The present invention provides DCT transforms with no systemic 

error. Because there is no systemic error, the transforms are reversible, or 
lossless, transforms. These reversible transforms can be used for lossless 
compression. 

The present invention provides reversible DCT transforms which 
1 0 have low mismatch. Minimum quantization matrices are given for ±1 
mismatch of quantized coefficients. If the minimum or greater 
quantization is used, the resulting coefficients can be used with any 
inverse DCT. 

The present invention may be implemented in hardware of 
1 5 software, or a combination of both. 

System Overview 

The reversible DCT of the present invention may be used in 
lossless or lossy systems containing either a reversible inverse DCT to 
20 obtain exactly what was originally input or containing a prior art (not 
reversible) inverse DCT. A prior art DCT would be able to take the 
output of the reversible DCT because of its low enough mismatch with 
the true DCT to obtain exactly the same result as the normal DCT. In 



other words, a MPEG or JPEG decoder with a legacy DCT decoder may be 
used with the reversible DCT of the present invention. 

Figure 1 is a block diagram of one embodiment of a lossless and 
lossy DCT based compression system. Note that although the present 
5 invention is described at times in terms of a DCT-based system, the 
present invention is applicable to other block-based transforms. 
Referring to Figure 1, input data 100 (e.g., an input image) is compressed 
with a reversible DCT based compressor 101 of the present invention. 
The input image 100 may be retrieved from a memory or received from a 

1 0 channel, both of which have not been shown to avoid obscuring the 
present invention. The input image may be generated by a camera, a 
digitizer, a scanner, a frame grabber, or other well-known or similarly 
functioning device. The results of the compression are a plurality of 
coefficients that may be output to a channel or to a storage device. Note 

1 5 that other types of compression may follow or precede the use of the 
DCT-based compressor. 

For lossless decompression, a decompressor with a reversible 
inverse DCT (IDCT) 102 is used on unquantized coefficients to exactly 
reconstruct the original. For lossy decompression, transform coefficients 

20 are quantized and then may be decompressed with a decompressor using 
any inverse DCT (IDCT) 103. As discussed above, the lossy decompressor 
may be a legacy system such as a JPEG or MPEG compliant decoder. 
In one embodiment, the DCT compressor receives pixel 
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components into a DCT transform, the output of which imdergoes zigzag 
ordering to produce frequency coefficients. Thereafter, the coefficients 
typically undergo lossless entropy coding. Similarly, in the inverse DCT 
compressor, frequency coefficients undergo lossless entropy encoding and 
5 then are input to a zigzag unordering block and thereafter to a DCT 
transform to retrieve the pixel components. 

Compressor 101 is shown coupled to decompressors 102 and 103 
through a channel or storage device 104. They may not be physically 
coupled together at all. That is, data may be compressed and stored using 
1 0 the compressor and an entirely separate decompression system may 
access the information, or copies thereof, to access the compressed 
information. In this manner, the channel or storage is transparent. 

Figure IB illustrates is a block diagram of one embodiment of the 
compressor of the present invention. Referring to Figure IB, the 
1 5 compressor includes color space or subsampling block 121 which 

performs color space conversion or subsampling of the input data. This 
is an optional block and may not be included in some compressors. In 
one embodiment, the color space performed by block 121 is reversible. 

The output of color space/subsampling block 121 is coupled to 
20 reversible DCT 122. The transformed values output from reversible DCT 
122 are coupled to the input of zigzag ordering block 123, which performs 
well-known zig-zag ordering techniques. It should be noted that this 
zigzag ordering block 123 is also optional. The output of zigzag ordering 



block 123 is coupled to run length block 124 which identifies run lengths 
of zeros. The output of run length block 124 is coupled to the input of 
Huffman coder 125, which performs Huffman coding. The output of the 
Huffman coding block is coupled to the input of signaling block 126 
5 which sets forth the signaling for the decoder to indicate to the decoder 
what type of quantization or decoding options were taken to enable the 
decoder to effectively decode the encoded data. In one embodiment, 
signaling block 126 generates a header that precedes the compressed data 
and indicates to the decoder the information to enable decoding. 

1 0 Optionally, quantization with scale factors may be applied after the 

reversible DCT block 122 and prior to zigzag ordering block 123. Such 
quantization with scale factors is described in more detail below. 

Figure 1C is a block diagram of an alternate embodiment of the 
compressor of the present invention Referring to Figure 1C, color 

1 5 space/subsampling block 121 is coupled to reversible DCT 122. The 

output of reversible DCT 122 is coupled to an optional, quantization with 
scale factors block 127. The output of the quantization with scale factors 
block 127 is coupled to the input of context model 133. Context model 133 
produces the context for the data. These contexts are forwarded to the 

20 probability estimation machine (PEM) 134. The PEM 134 generates 
probability estimates for the data based on contexts received. These 
probability estimates are output to bit stream generator (BG) 135 which 
generates the output bit stream based on the context from context model 
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133 and the probability estimates from PEM 134. The output of bit stream 
generator 135 is coupled to signaling block 126, 

Figure 2 is a block diagram of an example application of the present 
invention to a video authoring system. Referring to Figure 2, one or 
more input devices, such as cameras 201, capture or obtain video images. 
During capture, video is compressed losslessly by lossless compressor 202, 
which is coupled to camera(s) 201. In one embodiment, this allows 
approximately a factor of two savings in bandwidth and storage while not 
introducing any degradation. In other words, there are no artifacts. 
Although the eventual target compression ratio for video is typically 
100:1 lossy compression, initial lossless compression preserves 
information for enhancement, digital effects and any frame to be a high 
quality I-frame (for video compression). I-frames are well-known in the 
art of video compression and are compressed like a still image according 
to such compression standards as MPEG and HDTV. 

The output of compressor 202 is coupled to extraction block 203. 
For editing, quantized DCT coefficients can be extracted by extraction 
block 203, (transcoded if necessary) and fed to a motion JPEG 
decompressor 204 to which it is coupled. Extraction block 203 may 
operate by determining which frames are desired and /or selecting only a 
certain number of bits of each coefficient. For instance, Table 13 described 
below indicates the number of bits to discard, (in other words, which bits 
to keep). In another embodiment, extraction block 203 may only select 
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some of the blocks, thereby clipping the image. 

The motion JPEG decompressor 204 may be a low cost device or 
any legacy device. Because the compressed data is already in the DCT 
transform domain, the computation required to try different cuts and to 
5 experiment with different quantizations is reduced. Thus, this 
embodiment allows information to be viewed as video real-time, 
without very much extra processing. 

After the editor has decided what information to keep (e.g., what 
frames will be in the final version), a lossless decompressor, such as 
1 0 decompressor 205, can be used to recover the original data. Note that the 
data may be retrieved from a store that contains only the edited data or 
which contains all or some portion of the original input data. In this 
case, some logic or processing would be needed to access the correct 
information for decompression. This processing /logic would be well- 
1 5 known to one skilled in the art. 

An enhancement mechanism 206 may be coupled to decompressor 
205 to enhance or preprocess the original data, if necessary, without the 
possibility of compression artifacts being exaggerated. Examples of such 
enhancement or preprocessing include enlarging part of an image, 
20 interpolate between frames to do slow motion, sharpening, noise 

reduction, etc. These and other well-known enhancement mechanisms 
are well-known in the art. 

After any enhancement, a compressor 207 performs a full MPEG 
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compression with motion compensation to generate the final 
compressed data. Compressor 207 is well-known in the art. 

While the reversible DCT could be used with any lossless 
decompression application, it is most useful when used with legacy lossy 
DCT based systems. Other unified lossy/lossless compression system 
such as compression with reversible wavelets might be used if legacy 
system compatibility is not important. 

The present invention may be extended to any block based 
transform or any non-overlapped transform that can be decomposed into 
2-point rotations. For example, the present invention may be used with 
the following transforms: DFT/unitary DFT, cosine, sine, Hadamard, 
Haar, Slant, Karhunen-Loeve, Fast KC, Sinusoidal transforms, a SVD 
transform, lapped orthogonal transform (LOT), as well as others. See 
Jain, Anil K., Fundamentals of Digital Processing . Prentice-Hall, Inc. 1989, 
pgs. 132-138. Given these examples and the examples described below, it 
would be apparent to one skilled in the art to implement other 
transforms. 

Fast DCT Decompositions With the APT 

The Allen Parametrized Transform (APT), formally referred to as 
the Generalized Chen Transform (GCT), reduces the DCT and a family of 
other related transforms to a cascade of "integer rotations". In one 
embodiment, each rotation comprises a transform with the absolute 
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value for its determinant being 1. The present invention obtains a 
reversible DCT by decompressing the DCT into a multiple reversible 
components. Because the individual parts are reversible, the DCT is 
reversible. 

5 Figure 3A illustrates a block diagram of a ID, 8-point forward APT. 

Most of the APT transform is composed of two point rotations which are 
labeled by the arc tangent of a rotation angle. (The rotations are shown as 
"clockwise" and with their determinant equal to -1.) 

Referring to Figure 3A, the 8-point transform can be grouped into 
1 0 four initial rotations by 45° (arctan=l) 340, a 4-point APT 320, and a 
"subsidiary matrix" 330. The subsidiary matrix 330 contains two 
multiplications in addition to multiple 2-point rotations. 

Thus, there are three sets of rotations that form the forward APT 
transform. First, a set of 2-point (2x2) rotations 301-304 provide an input 
1 5 stage. Outputs from each of rotations 301-304 are coupled to the inputs of 
four point APT block 320, which contains 2-point rotations 305-308, and 
subsidiary matrix 330, which contains 2-point rotations 309 and 312-315 
and multipliers 310 and 311. 

Specifically, rotation 301 receives inputs 0 and 7 corresponding to 
20 two input data samples and generates one output to an input of rotation 
305 and another output to an input to rotation 312. Rotation 302 is 
coupled to receive input data samples 1 and 6 and provides two outputs, 
one coupled to an input of rotation 306 and one coupled to the input of 
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rotation 309. Rotation 303 is coupled to receive input data samples 2 and 
5 and generates two outputs, one of which is coupled to the other input 
to rotation 306 and another coupled to the other input to rotation 309. 
Rotation 304 is coupled to receive input data samples 3 and 4 and 
5 generates two outputs, one of which is coupled to the other input of 
rotation 305 and an input to rotation 313. 

Rotation 305 generates two outputs, one of which is coupled to an 
input of rotation 307 and the other is coupled to an input of rotation 308. 
Rotation 306 generates two outputs, one of which is coupled to the other 

1 0 input of rotation 307 and the other of which is coupled to the other input 
to rotation 308. In response to these inputs, rotation 307 generates the 0 
and 4 outputs, while rotation 308 generates the 2 and 6 outputs. 

With respect to the subsidiary matrix, rotation 309 generates two 
outputs coupled to multiply-by-R blocks 310 and 311. The output of 

1 5 multiply-by-R block 310 is coupled to the other input of rotation 312, 

while the output of multiply-by-R block 311 is coupled to the other input 
to rotation 313. In response to its inputs, rotation 312 generates two 
outputs that are coupled to an input to rotations 314 and 315. Similarly, 
in response to its inputs, rotation 313 generates outputs which are 

20 coupled to an input to rotation 314 and input to rotation 315. In response 
to these outputs, rotations 314 and 315 generate the 1 and 7 outputs and 
the 3 and 5 outputs respectively. The A, B, and C rotations will be 
described in more detail below. In one embodiment, each of rotations 
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301-304 may be the S-transform. However, in such a case, mismatch may 
suffer. 

The subsidiary matrix shown in Figure 3A is the Chen form. An 
alternative due to Hein and Allen, J. Allen, and described by J. Allen in, 
"Generalized Chen Transform: A Fast Transform for Image 
Compression," Tournal of Electronir Tmag-^g Vol. 3(4), October 1994, pgs. 
341-347, is shown in Figure 4. Referring to Figure 4, the subsidiary matrix 
comprises six rotations (by angle). A pair of rotations by an angle of a 
rotation by 45° (or arctan =1) are coupled to receive two inputs each and 
generate two outputs. One of the outputs of each of rotations 401 and 402 
is coupled to the inputs of rotation 403, while the other two outputs of 
rotations 401 and 402 are coupled to the inputs to rotation 404. In 
response to these inputs, rotations 403 and 404 generate two outputs. 
Rotations 403 and 404 comprise the B rotation. One of the outputs of 
each of rotations 403 and 404 is coupled to the inputs of rotation 405 
while the other outputs of each of rotations 403 and 404 is coupled to the 
inputs to rotation 406. Rotations 405 and 406 comprise the A and C 
rotations respectively. Each of rotations 405 and 406 generate the two 
outputs, 1 and 7 and 5 and 3, respectively. 

In one embodiment, the rotations are 2 point (2x2) rotations. Each 
rotation may comprise a 2 point transform or filter. 

The outputs are scaled to match the DCT. That is, the present 
invention generates outputs that require the use of scale factors to change 
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the outputs to match those that would result had a floating-point DCT 
been used. For lossy compression /decompression, scale factors may be 
combined with quantization factors. The scale factor used for each output 
can be determined from the product of the individual scale factors for 
5 each 2-point rotation. For the 2-point rotation matrix of the form shown 
in Figure 3A, the scale factor for both outputs of every rotation is given by 
the following equation: 

scalefactor = * * 



10 




# 2 +i 



For the following 2-point transforms: 
the scale factor is 



-4 a b l 

Lb -aj 



'a 2 +b 2 



For the following 2-point transforms: 

n 

the scale factor is ; for an output due to a,b and ■ i for an 

Va 2 +b 2 Vc 2 + d 2 

1 5 output corresponding to c,d. 

The separable two dimensional (2D), 64 point DCT (APT) can be 
implemented with eight ID, 8-point DCTs (APTs), a transpose, and 
another eight ID, 8-point DCTs (APTs). 

Figure 3B illustrates intermediate values in the APT which have 
20 the same scale factor. Referring to Figure 3B, each shaded lines indicates 
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inputs that have the same scale factor. Using the same scale factors 
constrains the divisors in two-point transforms. For example, most 
rotations by 1 (all but 309) are not required to have the same scale factor 
for both outputs, so an unbalanced transform such as the S- transform 
could be used. In contrast, the cascade of a rotation by 1 followed by 
multiplication by R (309) must have the same scale factors on the output 
as the input. 

Referring to Figure 3B, the two inputs for rotation 307 have the 
same scale factors. The two inputs to rotation 308 have the same scale 
factors. The two inputs to rotation 314 have the same scale factors and 
the inputs to rotation 315 have the same scale factors. The inputs to 
rotations 305 and 306 are the same. In the case of rotation 305, this would 
constrain the upper branches from each of rotations 301 and 304. With 
respect to rotations 312 and 313, not only do their inputs have the same 
scale factors, but also all the lower branches from each of rotations 301 
and 304 have the same scale factors. Because the scale factors of the lower 
branches output from rotations 301 and 304 have the same scale factors as 
the lower branch outputs of rotations 302 and 303, then the scale factors of 
all inputs to the subsidiary matrix are the same. 

The product of the scale factors of two outputs is the amount of 
expansion. Therefore, to be efficient, the product of both scale factors 
must ideally be 1 to prevent expansion. In one embodiment, to be 
reversible, both scale factors are 1. In alternative embodiments, the scale 
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factors can be slightly different. For example, both scale factors could 0.99. 

Table 1 illustrates values for APT parameters for three different 
embodiments. The first set of parameters are the irrational numbers that 
result in the DCT. DCT implementations (APT or other) for compression 
cannot use the irrational values. All actual DCT implementations 
approximate irrational parameters, even if the approximations are very 
accurate high precision floating point approximations. The APT uses 
rational approximations with small integers, which leads to tractable 
reversible implementations. 

Table 1 - APT parameters 

DCT APT1 APT 2 APT 3 

A TAN 7^/16 -5.0273 5/1 = 5.0000 5/1=5.0000 643/128 = 5.0234 

B TAN 6 71 /16 « 2.4142 12/5 = 2.4000 128/53 = 2.4000 128/53 = 24151 

C TAN 5 /T /16 - 1.4966 3/2 = 15000 3/2 = 15000 383/256=1.4961 

R ISQRT 1/2 - 0.7071 128/181=0.7072 128/181 = 0.7072 128/181 = 0.7072 

Table 1 shows three sets of APT parameters which trade-off 
simplicity vs. mismatch. APT 1 is simple and good for compression. The 
other examples, APT 2 and APT 3, are closer approximations to the 
irrational transform. APT 3 meets the COTT Rec. HJ261 (IEEE std 1180- 
1990) accuracy test. 

The choice of AFT parameters is not the only source of mismatch 
in a reversible transform. Reversible, efficient transforms require careful 
(reversible) rounding to integers at each step of the transform. These 
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rounding operations also cause mismatch. Some mismatch is 
unavoidable because methods that result in the same coefficients as a 
floating point implementation cannot be efficient, reversible. Since 
mismatch due to rounding usually dominates mismatch due to 
5 parameter choice, the APT 1 parameters may be a good choice. However, 
the techniques of the present invention could be applied to other 
parameters. 

It should be noted that these APT parameters may be adjusted to 
obtain other transforms, which may or may not be reversible. 

10 

Reversible DCT Implementations 

In the present invention, each 2-point rotation in the APT 
components are made reversible. By making each reversible, the entire 
APT is made reversible because each step may be reversed. In addition to 

1 5 efficiency, two other properties are desirable: balanced scale factors and 
no internal rounding. 

A 2-point transform has "balanced" scale factors if the scale factors 
for both outputs are the same. For a transform to be efficient (or almost 
efficient), it's determinant is ±1 (or almost ±1). If the determinant is 

20 constrained to be ±1, the product of the scale factor for the two outputs is 
1. Having both scale factors equal to 1 is desirable. In another 
embodiment, one scale factor is the reciprocal of the other. In this case, 
one scale factor is greater than 1. In this manner, the determinant will be 
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±1. A scale factor greater than 1 causes quantization, resulting in 
mismatch. 

Note that the scale factors in the equation given above are for an 
APT that is not efficient so their product is not one. Having both scale 
5 factors less than 1 leads to good rounding allowing for low mismatch, but 
such a system is not reversible, efficient. 

Rounding at each step allows reversibility. A 2-point rotation with 
n no internal rounding" indicates that at most only two rounding 
operations at the output of each step are performed. Some 
1 0 implementations have additional rounding operations inside the step, 
for example the ladder filter implementations described below. Extra 
rounding operations increase mismatch. 

When used for lossy compression, the DCT is unitary so the same 
transform can be used for both the forward transform and the inverse 
1 5 transform. However, in the present invention, for reversible 
implementations, the inverse transform inverts the rounding. 
Therefore, the inverse transform has the inverse data flow of Figure 3 
with each forward 2-point transform and multiplication replaced with 
the corresponding inverse transform. 

20 

Reversible Implementations Without Internal Rounding or Look Up 
Tables 

In one embodiment, the present invention provides reversible 
implementations of 2-point rotations and multiplications that do not 
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require internal rounding or look up tables. For parameters that have 
efficient, balanced 2-point rotations of this type, these are important 
building blocks. Some 2-point transforms are described below that are 
not balanced or only almost efficient. Ladder filter and look up table 
5 alternatives are provided. 

The choice of offsets often controls achieving reversibility. A 
discussion of how only some offsets results in reversible transforms is 
given below. 

10 "1": 1,1-transform, S -Transform-unbalanced 

In one embodiment, the "1" blocks may be implemented with the 
following transform where a and b are the inputs to the forward 
transform and x and y are the outputs of the forward transform: 
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Note that the floor ((LJ)) and ceiling ([."]) functions mean to round 
towards negative infinity and positive infinity respectively. 

In one embodiment, scale factors are V2 and 1 / V2 respectively. 



20 ~A":5,l-transform - unbalanced 

The following is one embodiment of the "A" rotation. 
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5a 



26 J L 26 J 

y = a-5b b = x-l + \ — 

L 26 J 

where the recovered least significant bits are given by the equation (i.e., 
rounded away bits): 

5 s (5y- 13) mod 26 
In this embodiment, scale factors are V26 and 1 / V26 respectively. 



' A" :S ,1-transform - balanced, inefficient 

The following is an alternate embodiment of the A rotation. 



where 



S = (-(25* + 5y - 12)) mod 26 
6\ = S mod 5 

•-HI 

This transform has determinant 26/25 = 1.04. Therefore, the 
redundancy is log2l.04 = 0.06 bits. It is inefficient, but close enough to 
1 5 efficient to be useful for lossless compression. Because it is balanced, it is 
more useful for lossy than the balanced efficient version. 
In one embodiment, scale factors are both 5/ V26 . 
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"A":60,U-transform - balanced, efficient 

Another alternative embodiment of the "A" rotation is as follows: 

| 60fl + lU> + 30 | 1 60;t + lly + 30 | 
5 L 61 J a = [ 61 J 

|na-60* + 30| , |lljt-60y + 30| 

""L 6i — J* = L — 6i — J 

This transform is balanced and efficient. This transform uses 
11,60,61 which is a Pythagorean triplet a,b,c with b+l=c and a2=2b+l. 
However, the result of 60/11 = 5.4545, which is not a very good 
approximation for tan 7ji/16 = 5.0273. Here, the closeness to the DCT 
1 0 has been sacrificed for balanced, efficiency and simplicity in computation. 

In this case, scale factors are both 1. 
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'B " -.12,5 -trans form 

The following is one embodiment for the "B" rotation: 



x _j ^a-126 + 6 j a _ p2x + 5y-6 j 
_ I 50 — 12^-1-6 | . |5z-12y+6| 

y= [ la J fc= L — —J 

This is both balanced and efficient. The numbers 5,12/13 are a 
Pythagorean triplet a,b,c with b+l=c and a2=2b+l. This leads to a very 
good 4-point APT (DCT). 
20 Scale factors are both 1. 
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Note that offsets are very important for reversibility. The choice of 
+6 for both offsets in the forward transform of the equation above results 
in a reversible transform, while other offsets do not. For example, if the 
offsets are both zero as in the first set of equations below, then the inputs 
5 a=0,b=0 and a=l,b=0 both result in x=0,y=0. 

It is apparent from this result that the selection of the offset can control 
reversibility. 

1 0 Another example is shown below where both offsets are +5. In 

this case, inputs a =4, b=0 and a=4,b=l, both result in x=4,y=l. 



13 J 

Most pairs offsets do not result in a reversible transform. Of the 

1 5 169 possible pairs of offsets (offsets are 0 12), the only 13 pairs of offsets 

that result in reversibility are 0,10; 1,5; 2,0; 3,8; 4,3; 5,11; 6,6; 7,1; 8,9; 9,4; 
10,12; 11,7 and 12,2. 
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C: 3,2-transform - unbalanced 

One embodiment of the "C" rotation is as follows: 



..[SijjS+Sj ,^., + |2t±iSJ 

y = 2a-3b b .2»-l|» ^* 28 J 

5s(6-5y)mod 13 

5 This is an efficient transform. In this case, scale factors are Vl3 and l/Vl3 
respectively. 



m C": 3,2'transform - unbalanced with growth in sum 

An alternate embodiment of the W C rotation, which is unbalanced 
1 0 with growth in the sum, yet efficient, is as follows: 



$s(6 + 5;c)modl3 
In this case, scale factors are lVl3 and Vl3 respectively. 

It is convenient in unbalanced transforms to divide the sum by the 
1 5 larger divisor. This leads to minimum growth in coefficient size. 

However, the sum leads to more visually relevant coefficients. Using the 
larger divisor on the difference and allowing more growth in the sum 
leads to lower mismatch in the more visually relevant coefficients. 
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"C :4,3-transform-balanced 

An alternate embodiment of the "C" rotation, which is balanced is 
as follows: 

|4a + 3fc + 2| |4x + 3y + 2| 



This transform is balanced and efficient. Again, the number set 3,4,5 is a 
Pythagorean triplet a,b,c with b+l=c and a 2 =2b+l. However 4/3= 1.3333 is 
not a very good approximation for tan 5rc/16= 1.4966. 
Scale factors are both 1. 



The Multiplier m R": V2 

In one embodiment, the multiplication factor using an integer 
approximation of V2 . The R factor normalizes the subsidiary matrix. 



L 181 J fl = L 256 J 



15 5 = (90-181x)mod 256 

0£5<181 



Non-PCT Transforms 

Figure 5A illustrates and 8-point Hadamard transform. Referring 
to Figure 5 A, rotations 501-512 comprise 2-point rotations by tan(7t/4)=l. 
20 Rotation 501 is coupled to receive input data samples 0 and 7 and 
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generate outputs to rotations 505 and 507. Rotation 502 is coupled to 
receive input data samples 1 and 6 and generate outputs to rotations 506 
and 508. Rotation 503 is coupled to receive input data samples 2 and 5 
and provide outputs to rotations 506 and 508, while rotation 504 is 
5 coupled to receive input data samples 3 and 4 and provide outputs to 
rotation 505 and 508. 

In response to its inputs, rotation 505 generates outputs to 
rotations 509 and 510. In response to its inputs, rotation 506 generates 
outputs to rotations 509 and 510 as well. In response to these inputs, 

1 0 rotation 509 generates output samples 0 and 4, and in response to its 
inputs, rotation 510 generates output samples 2 and 6. 

Rotation 507 generates outputs to rotation 511 and 512. Rotation 
508 also generates outputs to rotation 511 and 512. In response to these 
inputs, rotation 505 generates output samples 1 and 5, while rotation 512 

1 5 generates output samples 3 and 7. 

Figure 5B shows an 8-point Haar transform. Referring to Figure 
5B, the Haar transform comprises rotations 520-526 which are each 2- 
point rotations by tan(7t/4)=l. Rotation 520 is coupled to receive input 
data samples 0 and 1 and generate output data sample 4 and one output 

20 to rotation to 524. Rotation 521 is coupled to receive input data samples 2 
and 3 and generate outputs to rotation 524 and the output data sample 5. 
Rotation 522 is coupled to receive input data samples 4 and 5 and 
generate outputs to rotation 525 and output data sample 6. Rotation 523 
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is coupled to receive input data samples 6 and 7 and generate outputs to 
rotation 525 and the output data sample 7. In response to its inputs, 
rotation 524 generates the output data sample 2 and an output to rotation 
526. Rotation 525 generates an output to rotation 526 and generates 
5 output data sample 3. Rotation 526 outputs samples 0 and 1 in response 
to its inputs. 

Figure 5C illustrates on embodiment of the 4 point Sine transform. 
Referring to Figure 5C, the Sine transform comprises rotations 531-534. 
Rotations 531 and 532 comprise 2-point rotations by tan(7i/4)=l, while 
1 0 rotations 533 and 534 comprise rotations by D which is set forth as the 
tan(0.1762rc). 

Rotation 531 is coupled to receive the input data samples 0 and 3 
and produce outputs to rotations 533 and 534, while rotation 532 is 
coupled to receive input data samples 2 and 1 and generate outputs to 

15 rotations 533 and 534. In response to their respective inputs, rotation 533 
generates output data samples 0 and 2, while rotation 534 generates 
output samples 3 and 1. 

Figure 5D illustrates one embodiment of the 4-point Slant 
transform. Referring to Figure 5D, the Slant transform comprises 

20 rotations 540-543. Rotations 540-542 comprise 2-point rotations by 
tan(7c/4)=l, while rotation 543 comprises a 2-point rotation by 
tan(0.1024jt). Rotation 540 is coupled to receive input data samples 0 and 
3 and provide outputs to rotations 542 and 543, while rotation 541 is 
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coupled to receive input data samples 2 and 1 and generate outputs to 
rotations 542 and 543. In response to its inputs, rotations 542 generates 
output data samples 0 and 2, while rotation 543 generates output samples 
3 and 1. Given these examples described above, one skilled in the art may 
5 implement other transforms as well. 



Fffirient. Reversible 2-point Rotations Using Ladder Filters 

Ladder filters can be used to implement any 2-point rotation in a 
reversible, efficient, balanced fashion. Ladder filters have both scale 
1 0 factors equal to 1. The equation below is a ladder filter decomposition for 
a determinant 1 (counterclockwise) rotation. 



cos 8 sin 8 
-sin 6 cosd 




. sin 8 

To be reversible and efficient, each multiplication is followed by 
1 5 rounding to integer as shown in Figures 6 and 7. To be reversible, 

multiplications by irrationals are performed the same in the forward and 

inverse transforms. 

Referring to Figure 6, a ladder filter implementation is shown 
having inputs 610 and 611. Input 611 is coupled to a multiplier 602 which 
20 multiplies input 610 by the quantity of cos8-l divided by sin8. The result 
of the multiplication is rounded to the nearest integer at block 603. The 
results of the rounding are added to input 611 by adder 604. The output 
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of adder 604 is coupled to multiplier 606 which multiplies the output of 
adder 604 by sin9. The result is rounded to integer at block 605. The 
results of the rounding are added to input 610 using adder 601. The 
output of adder 601 is one output of the ladder filter, output 612. The 
5 output of adder 601 is also input to multiplier 607 which multiplies the 
output of the adder 601 by the quantity of cos8-l divided by sinG. The 
results of the multiplication are rounded to integer by block 608. The 
results of rounding are added to the output of adder 604 using adder 609. 
The output of adder 609 is the other output of the ladder filter, output 
10 613. 

Referring to Figure 7, two inputs, inputs 701 and 702, are input into 

the ladder filter. Input 701 is input to multiplier 703 which multiplies 

input 701 by — t . The results of the multiplication are rounded to 

sin 6 

integer by block 704. The results of the rounding are subtracted from 
1 5 input 702 by subtractor 705. The output of subtracter 705 is coupled to the 
input of multiplier 706 which multiplies it by sin9. The results of the 
multiplication are rounded to integer by block 707. The results of the 
rounding are subtracted from input 701 by subtractor 708. The output of 
subtractor 708 is one output of the ladder filter, output 712. 
20 The output of subtractor 708 is also coupled to the input of 

multiplier 709 which multiplies it by ^^J* . The results of the 

sin 6 

multiplication are rounded to integer by block 710. The results of the 
rounding are subtracted from the output of subtractor 705 by subtractor 
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711. The output of subtracter 711 is the other output of the ladder filter, 
output 713. 

The effect of the three rounding operations and the effect of the 
precision of implementing the irrational multiplications causes 
mismatch error. Ladder filter implementations often have more 
mismatched error than other implementations. 

Instead of decomposing the whole DCT into 2x2 rotations, larger 
ladder filters can be constructed. For example, the 4-point DCT can be 
implemented as a ladder filter by decomposing into three matrices as 
shown below: 
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These matrices contain the following constants: 
1 



X = 



y = 



cos— 
8 

sin— 
8 



a = 



_ * + y + 2rxy-4ry' 



2ry 2 
-(x+3y + 2rxy) 
wry 2 
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a! = 2(-l + ry) 
bj =-l + — 

*y 

1 

Cl 2ry 

2 2 

dl = l-2rx+\ + 2- + — + 2iy 

y y y 

_ -(x 2 + 2xy + 2rx 2 y + y 2 = 2ry 3 

2y 2 

f - r (^2ry)(x 2 +y 2 ) 

1 y 
i 

•2 -J 

b,-I 

2 2 

c 2 = 1 - 2ry 

2 2 
e 2 = 1-rx-ry 

, 3 x 
2 2y 

Thus, the present invention provides a novel 4-point reversible, as 
well as performing an efficient, reversible 2x2 decomposition for the 4 
point (4x4) rotation. 

It should be noted that although in the above description the 
transform includes a 2-point DCT, 4-point APT and an 8-point x 8 non- 
trivial matrix, the present invention may be expanded to other sizes such 
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as 16x16, for example. 

Look Up Tables for Efficient, Reversible 2-point Rotations 

Ladder filters can be used to make an efficient, reversible 
5 implementation for any 2-point rotation. The present invention 
provides a look up table based method and apparatus for controlling 
rounding to create efficient, reversible transforms that have improved 
rounding. Improved rounding reduces mismatch error. Balanced 
transforms can be constructed, and if a transform is balanced, then both 
1 0 scale factors are 1. 

Given a transform with determinant greater than or equal to 1, a 
one-to-one or one-to-many mapping input values to transformed values 
is possible. For reversible transforms, only a one-to-one mapping is of 
interest. For transforms with a determinant slightly greater than one, a 
1 5 small number of the possible transformed values can be unused and the 
mapping can be treated as one-to-one. 

There are 2-point integer rotations that cannot be made reversible 
with any fixed choice of rounding offsets. For example, consider the 
following equations which is a 45° rotation using the approximation 
20 given for AFT parameter R in Table 1. 

rcos45° sin45°l 
[sin 45° -cos45°J = 



V2 



1 

V2 
V2 
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X ~ 181 
_ 128a- 1286 + g(a,fr) 

y ~ 181 

5 

_ 128(a + b)+ /((a + b) mod 1 8 1, (a - fc) mod 181) 

181 

_ 1 28(a - b) + g((a + b) mod 1 8 1, (a - b) mod 181) 

181 

This is not reversible for any constant rounding offsets. However, 
if the rounding offsets are functions of the inputs, then the function can 
be made to be reversible. That is, the rounding varies as a function of the 
1 0 inputs. Furthermore, in this case, the rounding offsets are only functions 
of the sum and difference of the inputs modulo the divisor of 181. An 
example of the function is described below in conjunction with Table 2. 
Therefore, there are only 181*181 = 32761 pairs of rounding offsets. 

In one embodiment, the modulo portion of the above equation is 
15 removed. 

Figure 8 shows a portion of the mapping of input values to output 
transformed values for the 45° rotation. The above equality may be 
rewritten as 
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The stun and difference of the inputs are s and d respectively (s=a+b, d=a- 
b). Note the parity of the sum and difference are the same; that is, both 
are even or both are odd. The shaded squares indicate pairs of values that 
cannot occur since the parity is not the same. Only the unshaded pairs of 
5 values actually occur. Also shown is the s and d divided by V2 with 
normal rounding to integer. The heavy lines group pairs of values with 
the same s I V2 and The mapping is one-to-one already for every 

heavy line region than has a single unshaded square. Regions with two 
unshaded squares indicate problems where "collisions" or "holes" occur, 

1 0 where normal rounding maps two possible inputs to the same transform 
values and they both would give the same answer. Regions with only a 
shaded square indicates "extras," i.e. transform output values that would 
not be used with normal rounding. The arrows show how with proper 
rounding, the mapping can be made to be one-to-one by using the output 

1 5 values for extras for the input values that are collisions. 

For example, where the s and d inputs are 2 and 2, the output will 
not be 1,1. Instead, it will be 0,2 (see arrow 801). When performing the 
inverse, a look-up table entry for 0,2 would point to output 1,1. The 
determinant ^ 1 condition guarantees that for each collision, there is at 

20 least one extra. If the collisions are represented by nearby extras, 
mismatch due to rounding is reduced and may be minimized. 

Figure 9 shows the collisions fO") and extras ("+") for a 45° 
rotation using the approximation 1 / V2 = 29 / 41 = 0.7073. (The smaller 
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denominator of 41 is used instead of 181 so all possibilities can be shown 
on the page. The corresponding figure for a denominator of 181 is 
similar.) In this example, the determinant is very close to 1(1.0006) and 
the number of extras is equal to the number of collisions 

The number of collisions or the number of extras that do not have 
a pair is indicative of the expansion of the transform. 

Table 2 shows an example mapping for a 5° rotation using the 
approximation 1/^2=5/7 = 0.7143. 



Table 2 - Example Mapping 
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6 


6 
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2 


3 


-2 


-1 
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This is not very accurate, but the denominator is small enough 



that the results of all possible (sum, difference) pairs of inputs can be 
listed on a page. For each pair, the sum of the squared error is listed. 
5 Note that except when both inputs are 0, there is some error even if the 
best rounding to integer is used. The average RMSE for rounding pairs to 
the closest integer is 1 / V2 = 0.289. The 5/7 approximation has four 
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collisions out of 25 possible input pairs. These four collisions increase 
the RMSE to 0.6529 for this approximation. The columns entitled 
"rounding offset" are the output of look up tables. For the forward 
transform, the columns "sum, difference inputs" are the inputs and for 
5 the inverse transform, the columns "integer output for reversibility" are 
the inputs. 

The 128/181 approximation given in Table 1 is reasonably accurate. 
The numerator 128 is a power of 2 which is computationally useful. The 
determinant is 1.0002 (log2l .0002=0.0003 bits) so it is very close to efficient. 
1 0 The average RMSE with a good look up table is 0.4434 and the peak error 
is 1.92. 

Forward Computation 

A complete forward computation of a rotation for the 2x2 DCT is 
1 5 accomplished as follows. The approximation 1 / V2 = 128 / 181 is assumed 
for this example. First, in order to compute the forward, the sum and 
difference of the inputs a and b are computed according to the following 
equations. 

sum = a + b 

20 difference = a - b 

Next, the sum and difference are divided by 181, saving the 
remainder, according to the following equations. (Note that 
128/181 = 181/256 can be used in some implementations to speed up the 
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division.) 

ss = sum / 181 
dd = difference / 181 
s = sum mod 181 
d = difference mod 181 
The look up table assumes the pair of modulo 181 values s,d have 
the same parity (they are either both even or both odd). If ss and dd do 
not have the same parity, then the parity of one of the modulo values is 
changed. The change is made so values stay in the range 0 . . . 180. In the 
pseudo-code below, MA " means exclusive OR. This step is needed for odd 
denominators, it is not needed for even denominators. 
The pseudo code is as follows: 

if (ss is odd and dd is even) or (ss is even and dd is odd) 
if (d==180) 

s' = s A 1 

else 

d* = d A l 

The square root of 1/2 multiplied by s and d can be determined 
using 128/181 (or 181/256) or a look up table. The rounding offset may be 
found in the look up table. In one embodiment, the rounding offsets are 
-L . . 1 so the data width of the look up tables can be two bits. The square 
root of the portion of the inputs represented by ss and dd is 128ss and 
128dd respectively, which may be implemented as a shift. 

x = sqrt(l/2) • s' + LUT_f[s',d'] + 128 * ss 
y = sqrt(l/2) • d' + LUT_g[s , ,d t ] + 128 * dd 
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for the equality: 
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Alternatively, the look up table may return both the square root of 
s (or d) and the rounding offset. In one embodiment, such look up tables 
5 have seven bits of data width. 

x = LUT_sqrtl/2_f[s',d'] + 128 * ss 
y = LUT_sqrtl/2_g[s',d'] + 128 * dd 
The values of s and d vary from 0 to 180 but not all pairs occur. In 
some cases where f and g are dimensional (10) arrays, indexing a ID look 
10 up table with s+181*d would waste almost half the memory locations. 
Because 181 is odd, using s72+181*d'/2 does not properly handle 
boundary conditions. The following indexing scheme may be used. 

index = s72 + d'*90 + (d+l)/2 
Figure 12 is a block diagram of one embodiment a rotation 
1 5 according to the present invention. Referring to Figure 12, inputs a and b 
are added by adder 1201 to produce sum (s), while inputs a and b are input 
into subtracter 1201 which determines the difference (d) of a-b. The sum 
(s) is input to divider 1203 which divides it by 183. The remainder output 
of divider 1203 is coupled to the inputs of parity correction block 1205 and 
20 the quotient output is coupled to multiplier 1206. The difference output 
from subtracter 1202 is input to divider 1204 which divides it by 181 and 
outputs the remainder result to the other input of parity correction block 
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1205 and outputs the quotient to the input to multiplier 1207. Parity 

correction block 1205 performs the parity correction described above and 

outputs 's and d' which are coupled to two inputs of look-up table (LUT) 

1208 and to multipliers 1209 and 1210 respectively. 

5 Multiplier 1206 multiplies the ss output from divider 1203 by 128 

and outputs the result to adder 1211. Multiplier 1207 multiplies the 

output of the dd output of divider 1204 by 128 and outputs the result to 
adder 1212. Multiplier 1209 multiplies s' by <J)£ and outputs the result to 

adder 1211, while multiplier 1210 multiplies d 1 by ^ out P uts 

1 0 result to adder 1212. 

LUT 1208 generates the f and g values as described above and 
outputs them to adders 1211 and 1212, respectively. Adder 1211 adds the 
inputs together to produce the x output of the rotation, while adder 1212 
adds its inputs to generate the y output. 

15 

Inverse Computation 

In one embodiment, in order to compute the complete inverse, the 
approximation of 1/ V2 = 128/181 is assumed. 

First, the inputs x and y are divided by 128, while saving the 
20 remainder, according to the following: 

ss = x / 128 
dd = y/128 
i = x mod 128 
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j = y mod 128 

Next the modulo 128 values are multiplied by the square root of 
two and the rounding offsets are subtracted. (This can be combined into 
one LUT.) Because i and j may be any value from 0 to 127, all (or most if 
there are unused extras) look up table entries may be used without 
needing a fancy indexing scheme. 

s = sqrt (2) * i - LUTJ_inverse[i,j] 
d = sqrt (2) * j - LUT_g_inverse[i,j] 

Afterwards, compensation is made for the case when the ss parity 
is not the same as the dd parity for odd denominators by using, in one 
embodiment, the following pseudo code: 

if (ss is odd and dd is even) or (ss is even and dd is odd) 
if (d==180) 

s' = s A l 

else 

d' = d A l 

The sum and difference are computed according to the following 
equations: 

sum = s' + 181 * ss 
difference = d* + 181 * dd 
Lastly, the sum and difference are changed back into original 
values according to the following equations: 

i 

a = sum/2 + (difference+l)/2 
b = sum/2 - difference/2 
The inverse may be implemented in a manner similar to that 
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shown in Figure 12 except the direction is reversed. Such an 
implementation would be apparent to one skilled in the art in view of 
Figure 12. 

5 Creating Look Up Tables for Rounding Offsets 

An extra is assigned to every hole. For very small look up tables, 
exhaustive search can be used to find the best mapping. For larger look 
up tables, there are several techniques that can be used to successively 
refine look up tables. 

1 0 The first technique is a deterministic assignment of extras to 

collisions. In one embodiment, the number of extras is no less than the 
number of collisions. The extras are spaced out with respect to the 
collisions to which they are assigned. This technique is fast and allows 
the process to be replicated at both ends. This technique also avoids 

1 5 having to transmit a look up table as one could be generated on the fly. 

for each collision_row 

determine the number of extra_rows needed to provide an 
extra for every collision in the current collision row. 
20 if a partial extra row is required, select the proper number of 

extras evenly spaced within the row 
sort all the extras to be used in column order 
assign extras to collisions in column order 

The spacing that occurs is based on the number of collisions to 

25 extras. By dividing the number of collisions by the number of extras, an 

index factor is generated. Rounding to the next integer for each provides 

a set of integers indicative of which collisions to use. 
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For illustration, consider the pattern of collisions and extras shown 
in Figure 9. There are 144 collisions in 12 rows of 12 each. There are 144 
extras in 8 rows of 9 each and 9 rows of 8 each. The assignments for the 
first three rows of collisions are as follows, the remaining rows are 
5 assigned in a similar fashion. 

12 collisions in first row 

use first extra row which has 8 extras in columns 3, 7, 13, 17, 21, 27, 
31,37 

1 0 need 4 extras from second extra row, out of a total of 9, use the ones 

in columns 4, 14, 24, 34 
The assignments are (extra row, extra column -> collision column) 
l,3->2; 2,4->6; 1,7 ->8; 1,13-412; 2,14->16; 1,17-»18; 1,21 -*22; 
2,24-»26; 1,27-430; 1,31 ->32; 2,34 ->36; 1,37 ->40 
15 12 collisions in second row 

use remaining 5 extras from second extra row, out of total of 8, use 

the ones in columns 0, 10, 20, 28, 38 
use 7 extras from the third row, out of a total of 8, use the ones in 
columns 3, 7, 13, 17, 21, 27, 31 
20 The assignments are (extra row, extra column -> collision column) 

2,0->2; 3,3 -»6; 3,7-*8; 2,10->12; 3,13->16; 3,17-*18; 2,20->22; 
3,21 ->26; 3,27-430; 2,28 ->32; 3,31 ->36; 2,38-440 
12 collisions in third row 

use remaining 1 extra from third extra row, out of a total of 8, use 
25 the one in column 37 

use 9 extras from the fourth extra row in columns 0, 4, 10, 14, 20, 24, 
28, 34, 38 

use 2 extras from fifth extra row, out of total of 8, use 3, 21 
The assignments are (extra row, extra column -> collision column) 
30 4,0->2; 5,3->6; 4,4->8; 4,10->12; 4,14-4 16; 4,20->18; 5,21 ->22; 

4,24->26; 4,28 ->3Q; 4,34->32; 3,36; 4,40 

Given a starting mapping, mappings can be- improved by gradient 

decent (swap extra /collision assignments if mismatch is reduced) or 

similar optimization procedures (e.g., simulated annealing, etc.). 
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Another optimization procedure is described in B. Kerninghan, Lin, An 
Efficient Heuristic Procedure for Partitioning Graphics, Bell Syst Tech. J., 
pp. 291-307, 1970. Optimization may be performed considering only 
collisions and extras or considering all input and output values. 
5 Optimization may be performed by swapping pairs of inputs and outputs 
or by rotating triplets of inputs and outputs. In one embodiment, swaps 
or rotations that reduce squared error are performed until no more 
improvements are possible. 

The following pseudo code is one embodiment of a high level 

1 0 optimization method. This illustrates a refinement procedure. This 
method allows for swapping pairs (previous assignments). It allows for 
swapping an un assigned extra with the extra in an assigned collision-to- 
extra pair. It allows for swapping where the error does not change, i.e., 
where the direction of the error is the only issue. A swap that does not 

1 5 change the error is made when it allows a future swap to improve error, 
that is part of a triple-swap or rotation of three pairs. 

4 

for each collision 

compute squared error of current assignment 

20 do 

for each extra 

initialize extra pair swap to "not swapped yet" (eg. -1) 
initialize extra triple swap "not swapped yet" (eg. -1) 
initialize swap gain to zero 
25 for k = first swap candidate extra (eg. 0) to last swap candidate 

extra (eg. number of extras -1) 
try an find a better assignment for extra[k] 
if any better assignments are found 
perform swaps 
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while any better assignments are found 

In order to calculate the squared error, with a rotation by an angle 
of q, the following procedure may be used. 

5 let XC be first coordinate of collision 

let YC be second coordinate of collision 
let XE be first coordinate of extra 
let YE be second coordinate of extra 
let SIN = sin q 
10 letCOS = cosq 

squared error = (COS*XC-round(COS*XE)) A 2 + (COS*YC- 
round(COS*YE)) A 2 

The pseudo code for one embodiment of the "try and find a better 
assignment for extra[k] M routine is as follows: 

15 

initialize squared error best_improvement for best swap to zero 
search for best pair swap between extrafk] and extras[n, n>k] 
if best pair swap has same squared error as without swap 

search for best triple swap between extrafk], extra[n] and 
20 extras[m,m>n or n>m>k] 

if extra[n] or extrafk] or extrafm] have already been marked 
for swapping ignore best triple swap 

if the best swap reduces squared error 

if extra[n] has already been marked for a pair swap 
25 mark the extra to be swapped with extra [n] as 

"not swapped yet" 
if extra [n] has already been marked for a triple swap 

mark the extras to be swapped with extrafn] as "not 
swapped yet" 

30 if extrafk] has already been marked for a triple swap 

mark the extras to be swapped with extrafk] as "not 
swapped yet" 

if a triple swap is the best swap and extrafm] has already been 

marked for a triple swap 
35 mark the extras to be swapped with extrafn] as "not 

swapped yet" 
if a pair swap is the best swap 
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mark extra[n] to be swapped with extra[k] 
mark extra[k] to be swapped with extrafn] 

else 

mark extra[n] to be triple swapped 
5 mark extra [k] to be triple swapped 

mark extra [m] to be triple swapped with extra [n] and 
extra[k] 

The pseudo code for one embodiment of the "search for best pair 
swap" routine is as follows: 

10 

for each extra[n] 

calculate swap error = squared error for extra[n],collision[k] + 

squared error for extra[k],collision[n] 
calculate current error = the sum of squared error for the 
1 5 current assignments of extra[n],extra[k] 

this_in\provement = current error - swap error 
if (this_improvement >= 0) and (this_improvement >= 
besMmprovement) 
best_improvement = this improvement 
20 best swap found so far is n 

The pseudo code for one embodiment of the "search for best triple 

swap" routine is as follows: 

for each extra [n] 

25 

calculate swap error = squared error for extra[m], collision [k] 
+ squared error for extra[n], collision[m] + squared 
error for extra [k], collision[n] 

calculate current error = current error - swap error 
30 if (this_improvement >=0) and (this_improvement >= 

besMmprovement) 

besMmprovement = this improvement 
best swap found so far is n 

The pseudo code for one embodiment of the "perform swaps" 

35 routine is as follows: 
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for each extra[k] 

if extra[k] marked 

n = extra to swap with extra[k] 
if n < k 

swap extra[n] and extra[k] 

calculate squared error of current assignment 

An Almost Balanced DCT Implementation 

Look up table based rounding allows implementation of arbitrary 
2-point rotations with low mismatch. The present invention allows for 
creating transforms that are efficient and almost balanced and that can 
then be implemented reversibly with the look up table technique of the 
present invention (or some other technique). 

A balanced efficient transform exists when the determinant of the 
transform is a perfect square. An almost balanced transform is created by 
multiplying all the values in the transform matrix by a constant. The 
constant is selected such that the determinant can be factored into two 
close equal factors. Table 3 shows some examples of almost balanced 
transforms. 
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Table 3 - Almost Balanced Transforms 
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2,3"C n 


13 


42 


(84a+126b)/156 
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The LCM column in Table 3 contains a least common multiple of 
the denominators, after any common factors in the numerators are 
removed. A look up table of size LCM^ is sufficient to implement the 



transform. Large values are broken into a quotient and a remainder after 
division by the LCD. All of the look up tables required for the transforms 
in Table 3 are too large to be easily understood examples. The 2,1 almost 
balanced transform with multiplier 2 is described as an example in the 
equation below. 




|det| = 20 = 5x4 



The two divisors are 5 and 4, which has balance ratio 125. This 
example requires only a table size of 1(£ = 100 and the table has a simple 
structure. 

Table 4 is the look up table for the transform. All except the 
highlighted squares are determined using the following equation. The 
highlighted squares indicate collisions assigned to extras. 
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4a + 2fc + 2| |2a-4fc + 2 



Table 4 - Look Up Table for 2,1 Almost Balanced Transform 
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Figure 10 is a plot of x,y pairs that occur from the equation above 
5 when a and b are in the range 0. . . .10. The circles and arrows show the 
mapping of collisions to extras. Appendix A contains one embodiment 
of source code which implements this transform. It includes both the 
look up table and the quotient/remainder processing needed to handle 
arbitrarily large values 

10 

8x8 Transforms 

A variety of the building blocks described above may be used in the 
various 8x8 reversible APTs, some of which are shown in Table 5. The 
Chen decomposition of the subsidiary matrix shown in Figure 3 is used 
1 5 except for the APT labeled Hein which uses the subsidiary matrix shown 
in Figure 4. The "efficient" and "efficient" Hein use the building blocks 
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of the reversible implementations described above that do not have 
internal rounds or look up tables, except for the "1" and "R" in the 
subsidiary matrix that is done with a look up table. Another APT uses 
ladder filter building blocks. The "almost efficient" APT is closer to 
balanced which leads to good lossy performance. The "almost efficient" 
APT has determinant 1.04 (log2l. 04=0.06 bits of redundancy). 

Table 5 - Building blocks used to create 8x8 reversible APTs 



APT 
parameter 



B 



1 (outside 
subsidiary 
matrix) 

1 and R 
(inside 
subsidiary 
matrix, 
before R) 

1 (inside 
subsidiary 
matrix, 
after R) 



efficient 



5,1 transform- 
unbalanced 



efficient Hein efficient 

Ladder 
filter 

12,5 transform Ladder 



"almost 
efficient" 

5,1 transform 

balanced, 

inefficient 



12,5 transform 12,5 transform Ladder 12,5 transform 

3,2 transform 3,2 transform Ladder 3,2 transform 

growth in 
sum 

S-transform S-transform Ladder LUT 



LUT 



LUT 



Ladder LUT 



S-transform S-transform Ladder LUT 



In one embodiment, a finite state machine (FSM) entropy coder 
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and a trivial context model losslessly codes and decodes with the various 
transforms, such as shown in Figure 1C. An example of an FSM coder is 
shown in U.S. Patent Nos. 5,272,478, 5363,099 and 5,475,388, each of 
which is incorporated by reference. 
5 Table 6 shows the growth in the size of coefficients (number of bits) 

for the ID 8-point efficient reversible APT. 



Table 6 - Growth in size 
of coefficients for 8-point efficient reversible APT. 
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10 As an example for this transform, if the inputs are 8 bits, the total 

of 64 bits of input would grow by 18 bits and would result in 82 bits of 
output. The growth for the 2D 8x8 transform can be determined by 
applying the ID results horizontally and vertically. Table 7 shows the 
growth in the size of coefficients for the ID 8-point "almost efficient" 

15 reversible APT. 



Table 7 - Growth in size of 
coefficients for 8-point "almost efficient" reversible APT. 
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As an example for this transform, if the inputs are 8 bits / the total 
20 of 64 bits of input would grow by 21 bits and would result in 85 bits of 
output (when adding the growth from all bits together). Also for 
example, in the 2-D case where ID results are applied horizontally and 
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vertically for the horizontal coefficient 2 and vertical coefficient 3, there is 
an additional 10 bits (as both are added 2+8=10). The good compression 
results are due to having no redundant least significant bits; the growth is 
mostly easy to compress more significant bits. 
5 To be reversible, an APT must output different coefficients than a 

floating point DCT, so some mismatch is unavoidable. However, a 
reversible APT is lossless without quantization. The lossless feature 
allows for no systemic error is the inverse transform is the inverse 
reversible APT. If required by an application, reversible APT coefficients 

1 0 could be inverse transformed to the original pixels and then forward 
transformed with a floating point DCT if exact DCT coefficients were 
needed. This would again lead to no mismatch. 

Tables 8-10 show minimum quantization matrices for various 8x8 
APTs. Minimum quantization matrices set forth an amount, or more, of 

1 5 quantization that if applied would result in the reversible APT coefficient 
differing from true DCT coefficients by no more than ±1. The smaller the 
minimum quantization values, the less mismatch error in the 
transform. The DC quantizer is shown in the upper left corner and the 
AC quantizers are in standard DCT (not zig-zag) order. The "8x8" 

20 efficient reversible APT and the ladder filter based APT both have 

relatively large minimum quantizers for DC and coefficients near DC. 
These transforms would therefore only approximate the DCT well at low 
compression/high quality. The "almost efficient" APT has smaller 
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minimum values in general and has much smaller values for DC and 
near DC. This APT approximates the DCT well at typical JPEG 
compression ratios. 

The "almost efficient" APT has the most mismatch (highest 
minimum quantizers) in coefficients generated with the "C APT 
parameter. A look up table based "C" 2-point rotation might further 
reduce mismatch. 

Table 8 - Minimum quantization matrix for 8x8 efficient reversible APT 
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Table 9 - Minimum quantization matrix for 
8x8 efficient reversible APT using ladder filter 
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The structure of the minimum quantization matrices for some 
transforms are explained by the structure of the APT scale factor matrices. 
The ladder filter implementation is an exception, all values in it's scale 
factor matrix are 1. Tables 11 and 1*2 show the scale factors for the 8x8 
efficient reversible APT and the "almost efficient" version. Large scale 
factors (greater than 1) result in large minimum quantization values. 
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Table 10 - Minimum quantization matrix for 
8x8 "almost efficient" reversible APT 
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Table 11 


• 

- Scale factors for 8x8 efficient reversible APT 
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Table 12 - Scale factors for 8x8 "almost efficient" reversible APT 
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Lossy Coding 

Lossy coding with the reversible APT starts with lossless encoding 
5 using the reversible APT. The decoding is lossy and may use a legacy 
DCT based decompressor such as a JPEG decoder. 

Reversible APT coefficients may be used in a lossy compression 
system such as JPEG in the same manner as regular APT coefficients. A 
JPEG quantization matrix is chosen. Each quantizer is divided by the 
1 0 corresponding APT scale factor, resulting a new combined quantizer and 
scale factor. The APT and the combined quantization and scale factor 
matrix are used as a replacement for the DCT and quantization in JPEG. 
Any quantization matrix can be used; however, mismatch will occur if 
the scale factor is larger than the quantizer. 
15 In an alternative embodiment, the quantization 
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division/multiplication is replaced with shifting to select desired bits. 
This reduces computational cost. It allows an embedded or multi-use 
system were more bits can be selected for higher quality up to lossless 
when all bits are selected. The quantizers are chosen such that when they 
are divided by the corresponding scale factor, they are a power of 2 (or 
approximately a power of two). 

JPEG has a progressive mode called successive approximation. 
(Although this mode is less well known and less frequently used than 
the baseline sequential mode of JPEG.) An alignment scheme can be 
chosen that results in a particular JPEG quantization. This can be used to 
generate coded data for the first stage of successive approximation which 
can be very similar to baseline sequential data if spectral selection is not 
used. Successive approximation allows the remaining data to be coded by 
bitplanes in an embedded fashion. The progressive JPEG also has spectral 
selection. Spectral selection allows bitplanes of only specified coefficients 
to be coded. Spectral selection can be used to specify which coefficients 
have bits in a bitplane versus coefficients which have already been fully 
described. If large quantization values were chosen for the first stage, all 
(or almost) all of the coefficients would be bitplane coded. 

If using JPEG progressive mode was not desired, transcoding can be 
used to create sequential lossless JPEG codes treams of different fidelities. 
APT coefficients can be coded lossless with some method, not necessarily 
JPEG compatible. To create a stream, lossless decoding is performed, a 
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desired quantization is performed either by division or shifting. The 
quantized coefficients can then be coded in a JPEG compatible way. There 
is a computational savings over lossless coding methods that do not use 
the reversible APT since no DCT is required during transcoding. 
5 Table 13 shows an example of bits to shift right for each APT 

coefficient using the "almost efficient" 8x8 reversible APT. This 
corresponds to a quantizer /scale factor of 2 n where n is the number of bits 
to shift right. Table 14 is the equivalent JPEG DCT quantization matrix 
that the shifts in Table 13 implement. Table 14 is similar to the 
1 0 psychophysical^ weighted luminance quantization tables typically used 
with JPEG. 

Tables 15 and 16 show the bits to shift and corresponding 
quantizers for close to uniform quantization using the "almost efficient" 
8x8 reversible APT. 

15 



Table 13 - Bits to shift right for "psychovisual" shift based quantization 
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Table 14 - Quantization matrix for "psychovisual" shifts 
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Uniform quantization gives the best rate /distortion according to the 



mean squared error (MSE) metric. 
5 Table 15 - Bits to shift right for "normalized" shift based quantization 
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Table 16 - Quantization matrix of "normalized" shifts 
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Implementations Issues 

The reversible APT has a higher computation cost than a regular 
APT because scaling and rounding is performed at each step. To partially 
compensate for this disadvantage, the register width for the reversible 
APT is reduced at every step. Small register width and the simple 
parameters used in calculations aid implementation. In software, 
multiplication and division operations can be replaced by look up tables. 
In hardware, dedicated, low-hardware-cost multiply-by-N and divide-by- 
N circuits can be used. 

For example, consider the implementation of part of the n B" 2- 
point rotation with two lookup tables described below and shown in 
Figure 11. In hardware, the two look-up tables could be replaced with 
dedicated logic. 
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J \2a + 5b + 6 
L 13 . 



Referring to Figure 11, the LUTs 1201 and 1202 operate as follows: 

5 LUT1: given a, returns dl = j^^J and rl = (12a)mod 13 
LUT2: given b, returns d2 = and r2 = (5b+6)mod 13 

This produces the following results: 

10 x = dl+d2 whenrl+r2<13 

x = dl+d2+l whenrl+r2>13 

Reversible transforms for unified lossy and lossless compression 

are extended to include the discrete cosine transform (DCT), the most 

popular transform for image coded. The reversible Allen Parameterized 

15 Transform (APT) implements the DCT as a cascade of "integer rotations/' 
each of which is implemented reversibly. The entropy of reversible APT 
coefficients was found to similar to the entropy of reversible wavelet 
coefficients. An "almost balanced" reversible APT sufficiently low 
mismatch to the floating point DCT so a legacy JPEG decoder can be used 

20 for lossy decompression. 

Whereas many alterations and modifications of the present 
invention will no doubt become apparent to a person of ordinary skill in 
the art after having read the foregoing description, it is to be understood 
that the particular embodiment shown and described by way of 
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illustration is in no way intended to be considered limiting. Therefore, 
references to details of the preferred embodiment are not intended to 
limit the scope of the claims which in themselves recite only those 
features regarded as essential to the invention. 



Thus, a reversible DCT-based system has been described. 
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Appendix A. Almost balanced 2,1 transform source code 
The following "awk" source code implements the almost balanced 
2,1 transform using a look up table as described above. 

#!/usr/bin/nawk-f$OS* 

# Copyright 1996, 1997 RICOH 

# integer division followed by "floor" rounding 
function mydiv (n,d) { 

m = int(n/d); 

if ((m*d !=n) && (n<0)) { 

return m-1; 
} else 

return m; 

} 

BEGIN { 

for (a=0;a<10;a++) { 
for (b=0;b<10;b++) { 

x = mydiv(4*a=2*b=2,5); 
y = mydiv(2*a-4b+2,4); 

# fix up boundaries so it tiles correcdy 
if ((x== 8) && (y==4)) 

if ((x~2) && (y==-6)) 
x-; 

# match internal collisions and holes 
if (hit[x y] ==1) { 

xl = x; 

if (hit[x y] == 1) { 
print "ERROR"; 
exit 1; 

} 

hit [x y] = 1; 

al = lut_a[xl y]; 

bl = lut_b[xl y]; 

el = xl - ((4.0*al+2.0»bl) / 5.0); 

eO = x - ((4.0»a+2.0*b) / 5.0); 

els = x - ((4.0»al+2.0*bl) / 5.0); 
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eOs = xl - ((4.0*a+2.0*b) / 5.0); 

if (els*els+eOs*eOs < el*el+eO*eO) { 

#swap assignments 

lut_a[xy] = al; 
5 lut_b[xy} = bl; 

lut_x[al bl] = x; 

lut_y[al bl] = y; 

lut_a[xl y] = a; 
1 0 lutjb[xl y] = b; 

lut_x[a b] = xl; 
lut__y[a b] = y; 

} 

} else { 

1 5 hit[x y] = 1; 

lut_a[x y] = a; 
lutjb[x y] = b; 
lut_x[a b] = x; 
lut_y[a b] = y; 

20 } 

} 

} 

# print the mapping 
for (a=0; a<10;a++) { 
25 for (b=0;b<10;b++) { 

x = lut_x[a b]; 
y = lut_y[a bj; 
el = x - (4.0*a+2.0*b) / 5.0; 
e2 = y - (2.0*a-4.0*b) / 4.0; 
30 error = el*el+e2*e2; 

print x " y M \t->" aV b"\f error; 

) 

print MM ; 

} 

35 # Check mapping for integers outside of 0..9 
lim = 25; 

for (a=-lim;a<lim+l;a++) { 
ad = mydiv(a,10); 

am = a - ad*10; 
40 for (b=-lim;b<lim+l;b++0) { 
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bd + mydiv(b,10); 
bm = b - bd»10; 
xm + lut_x[am bm]; 
ym = lut_y[am bm]; 
x = 8*ad + 4*bd + xm; 
y = 5*ad -10'bd + ym; 
print x ", "y"\t-< "a'V'b; 
if (hit2[x,y] !="") { 

print "ERROR: "x","y ,, ; ,, a" / V & hit2[ 

I 

hit2[x,y] = x Vy Ya","b; 

} 

print ""; 



CLAIM? 
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1 1. A compressor having a reversible Discrete Cosine 

2 Transform (DCT). 

1 2. The compressor defined in Claim 1 in a system having a 

2 decompressor. 

1 3. The system defined in Claim 2 wherein the decompressor is 

2 a decompressor with a reversible inverse DCT. 

1 4. The system defined in Claim 2 wherein the decompressor 

2 comprises a legacy decompressor with an inverse DCT. 

1 5. The compressor defined in Claim 1 wherein the DCT 

2 comprises a plurality of 2 point rotations. 

1 6. The compressor defined in Claim 5 wherein a plurality of 2 

2 point rotations comprise transforms. 

1 7. The compressor defined in Claim 6 wherein each of the 



2 
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transforms has balanced scale factors. 



1 8. The compressor defined in Claim 7 wherein the scale factors 

2 of both outputs of individual transforms are equal. 

1 9. The compressor defined in Claim 7 wherein the product of 

2 the scale factors for two outputs of a transform is 1. 

1 10. The compressor defined in Claim 7 wherein both scale 

2 factors of outputs of a transform are less than 1. 

1 11. The compressor defined in Claim 5 wherein each of the 

2 plurality of 2-point rotations is reversible. 

1 12. The compressor defined in Claim 11 wherein the plurality 

2 of 2-point rotations has no internal rounding. 

1 13. The compressor defined in Claim 5 wherein at least one of 

2 the 2-point rotations comprises an S-transform. 

1 14. The compressor defined in Claim 5 wherein at least one of 

2 the 2-point rotations comprises an unbalanced 5,1 transform. 
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15. The compressor defined in Claim 5 wherein at least one of 
the 2-point rotations comprises a balanced 5,1 transform. 

16. The compressor defined in Claim 5 wherein at least one of 
the 2-point rotations comprises a 60,11 transform. 

17. The compressor defined in Claim 5 wherein at least one of 
the 2-point rotations comprises a 12,5 transform. 

18. The compressor defined in Claim 5 wherein at least one of 
the 2-point rotations comprises a 3,2 transform. 

19. The compressor defined in Claim 5 wherein at least one of 
the 2-point rotations comprises a 4,3 transform. 

20. The compressor defined in Claim 5 wherein at least one of 
the 2-point rotations comprises a ladder filter. 

21. The compressor defined in Claim 20 wherein results of each 
multiplication performed in the ladder filter are rounded to an integer 
value. 

22. The compressor defined in Claim 5 wherein at least one of 



2 
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the 2-point rotations has rounding offsets that are a function of its inputs. 



1 23. The compressor defined in Claim 5 wherein at least one of 

2 the 2-point rotations has rounding offsets that are functions of the sum 

3 and difference of its inputs modulo a divisor. 

1 24. A block-based transform compressor comprising: 

2 a first plurality of rotations; 

3 a 4-point parametrized transform coupled to a first set of outputs of 

4 the first plurality of rotations and having a second plurality of rotations 

5 including a rotation by B; and 

6 a subsidiary matrix coupled to a second set of outputs of the first 

7 plurality of rotations, wherein the subsidiary matrix comprises a rotation 

8 by A and a rotation by C; 

9 wherein the first plurality of rotations, the 4-point parametrized 

1 0 transform and the subsidiary matrix operate as a reversible block-based 

1 1 transform. 

1 25. The compressor defined in Claim 24 wherein the rotation by 

2 B comprises a 12,5 transform. 

1 26. The compressor defined in Claim 24 wherein the first 

2 plurality of rotations comprise 2-point rotations. 
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1 27. The compressor defined in Claim 24 wherein the subsidiary 

2 matrix comprises: 

3 a first 2-point rotation having two inputs coupled to a first two 

4 outputs of the first plurality of rotations; 

5 a pair of multipliers coupled to individual outputs of the first 2- 



6 point rotation; 

7 a first pair of 2-point rotations coupled to receive outputs of the 

8 pair of multipliers and a second two outputs from the first plurality of 

9 rotations; 

1 0 the rotation by C and the rotation by A coupled to receive outputs 

11 of the first pair of 2-point rotations. 

1 28. A compressor comprising: 

2 an input; 

3 a reversible DCT having at least one transform comprising a look 



4 up table having a mapping of transform input values to transform 

5 output values, and wherein the mapping maps input values from a first 

6 group, in which rounding maps inputs to the same transform values, to 

7 transform output values that would not have been used with rounding. 

1 29. The compressor defined in Claim 28 wherein said at least 

2 one transform has a determinant greater than or equal to 1. 
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1 30. A method for creating a look up table for rounding offsets, 

2 said method comprising the steps of: 

3 generating a first mapping of input values to transform output 

4 values using an initial rounding; and 

5 for each row of collisions in the first mapping, wherein a collision 

6 is a mapping of inputs to the same transform output values, 

7 determine the number of rows, each containing extras 

8 which are needed to provide a transform output value that would not be 

9 used with the initial rounding, wherein each extra comprises a transform 

1 0 output value that would not be used with an initial rounding, 

1 1 select a number of extras evenly spaced within a row if a 

1 2 partial extra row is needed to provide one extra for each collision, 

1 3 sort the extras in column order, 

1 4 assign extras to collisions in column order so as to create a 

1 5 second mapping for use in the look up table. 

1 31. The method defined in Claim 30 further comprising the step 

2 of swapping pairs of input values and transform output values. 

1 32. The method defined in Claim 31 further comprising the step 

2 of rotating triplets of input values and transform output values. 



1 



33. A method for creating a look up table for rounding offsets, 
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said method comprising the steps of: 

for each collision in which there is a mapping of a plurality of 
inputs to the same transform output values, 

for each extra in which there is a transform output value that 
would not be used with an initial rounding, 

identify a swap with another extra based on predetermined 

criteria, and 

perform the swap. 

34. The method defined in Claim 33 wherein the 
predetermined criteria comprises square error, and a swap is identified 
where the square error is reduced. 

35. A compressor comprising: 

a reversible block-based transform; 

a coder coupled to the reversible block-based transform to code data 
drive from an output of the reversible block-based transform. 

36. The compressor defined in Claim 35 wherein the transform 
comprises a DFT transform. 

37. The compressor defined in Claim 35 wherein the transform 
comprises a cosine transform. 
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1 38. The compressor defined in Claim 35 wherein the transform 

2 comprises a sine transform. 

1 39. The compressor defined in Claim 35 wherein the transform 

2 comprises a Hadamard transform. 

1 40. The compressor defined in Claim 35 wherein the transform 

2 comprises a Haar transform. 

1 41. The compressor defined in Claim 35 wherein the transform 

2 comprises a Slant transform. 

1 42. The compressor defined in Claim 35 wherein the transform 

2 comprises a Karhunen-Loeve transform. 

1 43. The compressor defined in Claim 35 wherein the transform 

2 comprises a Fast KL transform. 

1 44. The compressor defined in Claim 35 wherein the transform 

2 comprises a sinusoidal transform. 



1 45. The compressor defined in Claim 35 wherein the transform 

2 comprises a SVD transform. 
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46. The compressor defined in Claim 35 wherein the transform 
comprises a lapped or orthogonal transform. 

47. A computer readable medium storing an executable 
program having sequences of instructions which, when executed by a 
processor, cause the processor to perform the following steps: 

receiving input data; and 

performing a reversible DCT transform. 

48. The medium defined in Claim 47 wherein said sequences of 
instructions further cause the processor to perform the step of quantizing 
coefficients generated by performing the reversible DCT transform, 
wherein the quantization is performed with scale factors. 

49. The medium defined in Claim 47 wherein said sequences of 
instructions further cause the processor to perform the steps of: 

zig zag ordering; 

generate run lengths of zero; and 

perform Huffman coding. 

50. The medium defined in Claim 50 wherein said sequences of 
instructions further cause the processor to perform the following steps of: 

generating contexts for each datum; 
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generating probability estimates associated with each 
context; and generating a bitstream based on contexts and 
probability estimates. 

51. A method of compressing data substantially as 
hereinbefore described with reference to the accompanying 
drawings . 

52. A data compressor constructed and arranged to 
operate substantially as hereinbefore described with 
reference to the accompanying drawings. 




Application No: 
Claims searched: 



GB 9808331.4 
1 and 28 



The 

Patent 
Office 




Examiner: John Coules 

Date of search: 9 September 1998 



Patents Act 1977 

Search Report under Section 17 

Databases searched: 



UK Patent Office collections, including GB, EP, WO & US patent specifications, in: 
UK CI (Ed.P): H4F FRT,FRG,FRW; G4A AJR 
Int CI (Ed.6): H04N 7/26,7/30,7/50; G06F 17/14 
Other: Online: WPI 



Documents considered to be relevant: 



Category 


Identity of document and relevant passage 


Relevant 
to claims 


X 


EP 0539155 A2 


(Canon) see particularly claims 8 and 12 


1 and 28 
at least 


X,P,& 


US 5703799 


(NEC) see whole doc 


1 and 28 
at least 


x,& 


JP 9-8665 


(NEC) see whole doc 


1 and 28 
at least 



X Document indicating lack of novelty or inventive step A 
Y Document indicating lade of inventive step if combined P 
with one or more other documents of same category. 

E 

& Member of the same patent family 



Document indicating technological background and/or state of the art. 
Document published on or after the declared priority date but before 
the filing date of this invention. 

Patent document published on or after, but with priority date earlier 
than, the filing date of this application. 



An Executive Agency of the Department of Trade and Industry 



